<template>
  <div class="file-list">
    <a-table
        row-key="id"
        :scroll="{ x: '100%', y: '100%', minWidth: 800 }"
        :data="props.data"
        :bordered="false"
        :pagination="false"
        :row-selection="isBatchMode ? rowSelection : undefined"
        :selected-keys="selectedFileIds"
        column-resizable
        @select="select"
        @row-click="handleRowClick"
    >
      <template #columns>
        <a-table-column title="名称">
          <template #cell="{ record }">
            <a-trigger
                trigger="contextMenu"
                align-point
                animation-name="slide-dynamic-origin"
                auto-fit-transform-origin
                position="bl"
                update-at-scroll
                scroll-to-close
            >
              <section class="file-name">
                <div class="file-image">
                  <FileImage :data="record"></FileImage>
                </div>
                <a-typography-paragraph copyable :copy-text="record.url">
                  <template #copy-tooltip>复制链接</template>
                  {{ getFileName(record) }}
                </a-typography-paragraph>
              </section>
              <template #content>
                <FileRightMenu :data="record" @click="handleRightMenuClick($event, record)"></FileRightMenu>
              </template>
            </a-trigger>
          </template>
        </a-table-column>
        <a-table-column title="大小" data-index="size" :width="150">
          <template #cell="{ record }">{{ formatFileSize(record.length) }}</template>
        </a-table-column>
        <a-table-column title="存储名称" data-index="name" :width="200" />
        <a-table-column title="修改时间" data-index="update_time" :width="200" />
        <a-table-column title="操作" :width="120" align="center">
          <template #cell="{ record }">
            <a-popover trigger="click" position="bottom" :content-style="{ 'padding': 0, 'margin-top': 0 }">
              <a-button type="text" @click.stop><icon-more :size="16" /></a-button>
              <template #content>
                <FileRightMenu
                    :file-info="record"
                    :shadow="false"
                    @click="handleRightMenuClick($event, record)"
                />
              </template>
            </a-popover>
          </template>
        </a-table-column>
      </template>
    </a-table>
  </div>
</template>

<script setup lang="ts">
import type { TableInstance, TableRowSelection } from '@arco-design/web-vue'
import FileRightMenu from './FileRightMenu.vue'
import type { QueryResponse } from '@/api/system/file'
import { formatFileSize } from '@/utils'

const props = withDefaults(defineProps<Props>(), {
  data: () => [], // 文件数据
  selectedFileIds: () => [],
  isBatchMode: false, // 是否是批量模式
})

const emit = defineEmits<{
  (e: 'click', record: QueryResponse): void
  (e: 'select', record: QueryResponse): void
  (e: 'right-menu-click', mode: string, item: QueryResponse): void
}>()

const FileImage = defineAsyncComponent(() => import('./FileImage.vue'))

interface Props {
  data?: QueryResponse[]
  selectedFileIds?: string[]
  isBatchMode?: boolean
}

// 文件名称带后缀
const getFileName = (item: QueryResponse) => {
  return `${item.name}`
}

const rowSelection: TableRowSelection = reactive({
  type: 'checkbox',
  showCheckedAll: true,
})

// 多选
const select: TableInstance['onSelect'] = (rowKeys, rowKey, record) => {
  emit('select', record as unknown as QueryResponse)
}

// 行点击事件
const handleRowClick: TableInstance['onRowClick'] = (record) => {
  emit('click', record as unknown as QueryResponse)
}

// 右键菜单点击事件
const handleRightMenuClick = (mode: string, item: QueryResponse) => {
  emit('right-menu-click', mode, item)
}
</script>

<style scoped lang="less">
:deep(.arco-table-td .arco-table-cell) {
  padding-top: 0;
  padding-bottom: 0;
}
.file-list {
  width: 100%;
  padding-top: 12px;
  overflow: hidden;
  .file-name {
    height: 100%;
    display: flex;
    align-items: center;
    padding-top: 6px;
    padding-bottom: 6px;
    cursor: pointer;
  }
  .file-image {
    width: 30px;
    height: 30px;
    margin-right: 10px;
  }
}
</style>
